草庐IT

sql - 连接分组的行

全部标签

go - 如何使用反射或其他方式将 interface{} 转换为 sql.NullString

我已经创建了一个map[string]interface{},并照此填充它。sli:=make(map[string]interface{})str:=new(sql.NullString)str.String="hello"str.Valid=truei64:=new(sql.NullInt64)i64.Int64=55i64.Valid=truesli["first"]=strsli["second"]=i64这一切都很好,但是当我尝试从map中的sql.NullString元素访问字符串时,我感到panic。interfaceconversion:interface{}is*sq

go - 如何连接忽略空字符串的结构的字符串字段?

我真的是Go的新手,所以需要一些建议。我有一个结构:typeEmployeestruct{NamestringDesignationstringDepartmentstringSalaryintEmailstring}我想将字符串字段连接成一种员工描述。所以,我可以说:toString(employee)并得到:JohnSmithManagerSalesjohn.smith@example.com我尝试获取每个字段,检查它们是否为空并将它们放入一个slice中并在最后加入它们employeeDescArr:=make([]string,0,4)ifstrings.TrimSpace(v

go - 如何访问未转换的 driver.Value sql.Rows slice

我的目标是获取原始driver.Value值,由sql驱动程序在其driver.Rows.Next()实现中反序列化。我想处理从驱动程序返回的值到所需目标类型的转换,而不是依赖Rows.Scan中内置的自动转换。请注意这个问题不会询问您是否“应该”使用Rows.Scan的意见。我不想使用它,我想请问是否有任何方法可以避免它。有意义的答案根本不使用Rows.Scan。WorkingwithUnknownColumns中说明的动态方法很糟糕:它调用Scan的所有开销并破坏源列的类型信息,而不是将实际的driver.Value分解为SqlBytes。以下hack有效,但依赖于sql.Rows

Go:使用 TCP 连接写入 header

我从这里用以下代码结构实现了一个TCP服务器:http://golang.org/pkg/net/#example_Listener我正在尝试从浏览器pingTCP服务器。TCP服务器能够写入我的浏览器。但是,它无法写入客户端header,因为它未使用HTTP协议(protocol)。如何保持TCP协议(protocol)和连接,但仍然能够写入浏览器的header? 最佳答案 HowdoIkeeptheTCPprotocolandconnectionsbutstillbeabletowritetothebrowser'sheader

sql - 将 int 转换为 int32

我正在努力从Db中提取行并将结果存储在slice/数组中我需要计算总记录数和总页数。pseudoCode::perPageint32:=(somenumber)totalRecords:=len(array)totalPages:=perPage/totalRecords我一直收到这个错误。terminal::`invalidoperation:perPage/totalRecords(mismatchedtypesint32andint)` 最佳答案 len(array)返回int将其转换为int32int32(len(array

sql - 如何在 SQL 查询中将 URI 作为字符串附加

看起来很简单,但我做不到。当浏览domain.com/post/1时,它应该显示id行的数据,其值为1。行id是整数(int4)。下面的代码,这是行不通的:packagemainimport"fmt"import"github.com/go-martini/martini"import"net/http"import"database/sql"import_"github.com/lib/pq"funcSetupDB()*sql.DB{db,err:=sql.Open("postgres","user=postgrespassword=apassworddbname=lesson4ss

string - Go中字符串变量的连接速度

我在这个网站上看到一个关于字符串连接速度的问题。在那个主题中,人们写了一些带有奇怪数字的短暂基准。HowtoefficientlyconcatenatestringsinGo?我决定检查这些速度并编写测试。我的测试显示了其他结果。在大尺寸上,“+”运算符比其他方法更快。是吗?这是我的代码。packagemainimport("bytes""fmt""runtime/debug""time")constvariations=30vartime1,time2time.Timevardelta,catcherstringvarx,deltaSize,k,dataSize,operations

sql - Golang sql 包查询比 PostgreSQL SQL 查询慢

我正在使用GolangSQL包来调用我的数据库。我正在使用准备好的语句,并且在列上有索引stmtHas:=db.Prepare(`SELECTvalueFROM`+tableName+`WHEREkey=$1;`)now:=time.Now()err:=db.stmtGet.QueryRow(key).Scan(&value)elapsed:=time.Since(now)fmt.Println(elapsed)这会打印-40.874782ms然而,与此相比,原始SQL查询花费的时间要少得多。EXPLAIN(ANALYZE,BUFFERS)SELECTvalueFROMtableNam

go - 初始化/管理并发 SSH 连接

我进行了高低搜索,但我不确定我是否使用了错误的关键字,但我无法理解这一点。我正在构建一个应用程序,它接收主机名列表并通过SSH连接到这些主机名。它旨在维护这些连接(并在断开连接时重新连接)。定期地,我的程序将接受指令并向部分/所有这些主机执行命令。我目前的问题是,我知道你不能初始化一个变量而不使用它,我必须为这些SSH连接动态创建变量,这样我就可以独立监控/管理它们(读/写,必要时重新连接等).由于我对go的了解有限,而且倾向于不小心使事情过于复杂,到目前为止,我想到的最好的方法是使用一个结构并为每个连接及其参数(主机名、用户名、密码、SSH配置详细信息、日志文件)附加位置等)。目前我

go - 将一个字符串连接到一个结构片段

我正在尝试创建一个端点GoAPI以供前端JavaScript图形库使用。应该发生什么:/data端点以获取JSON数据数组。数据只是一片go结构,在这个例子中只有两个,但它将超过10000。图形库需要额外的元数据。它被保存为一个名为AdditionalInfo的变量。问题是当我想对AdditionalInfo+AllAgents进行编码时,它不允许我将字符串与结构片段连接起来。在结构slice的末尾还需要一个]`使其成为有效的JSON问题:如何在结构slice的前后添加额外数据?将结构附加到结构slice是否有效?创建一个已知长度的slice然后使用范围附加到它会更好吗?package